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CONNECTION TABLE FOR INTRUSION DETECTION 

BACKGROUND 

This invention relates to techniques to detect network 
anomalies . 

15 Networks allow computers to communicate with each other 

whether via a public network, e.g., the Internet or private 
networks. For instance, many enterprises have internal networks 
(intranets) to handle communication throughout the enterprise. 
Hosts on these networks can generally have access to both public 

20 and private networks. 

Managing these networks is increasingly costly, while the 
business cost of network problems becomes increasingly high. 
Managing an enterprise network involves a number of inter- 
related activities including establishing a topology, 

25 establishing policies for the network and monitoring network 
performance. Another task for managing a network is detecting 
and dealing with security violations, such as denial of service 
attacks, worm propagation and so forth. 
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SUMMARY 

According to an aspect of the invention, memory device 
storing a data structure for tracking network behavior, the data 
structure comprising a connection table that maps each node of a 
5 network to a record object that stores information about traffic 
to or from the node and between that node and others nodes in 
the network. 

The connection table includes a plurality of records that 
are indexed by source address, destination address and/or time. 

10 The connection table is a plurality of connection sub-tables 
each sub-table having data pertaining to network traffic over 
different time scales. 

The connection sub-tables include a time-slice connection 
table that operates on a small unit of time and at least one 

15 other sub-table that operates on a larger unit of time than the 
time slice sub-table. The at least one sub-table holds records 
received from all collectors over the time scale of the table. 

The addresses that index the connection table are IP 
addresses. The addresses indexing the connection table include 

20 a physical layer address to IP address map that is used to 

determine Host ID. The host record of a first host also maps to 
a second host which communicates with the first host to a "host 
pair record" that has information about all the traffic from 
between the first and second hosts. The connection data 

25 structure enables a consuming device to obtain summary 

information about one host and about the traffic between any 
pair of hosts, in either direction. A record in the ^connection 
table stores a measure of the number of bytes, packets, and 
connections that occurred between hosts, during a given time- 

30 period. 

One or more aspects of the invention may provide one or 
more of the following advantages. The connection table is a 
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data structure that maps each host (e.g., identified by IP 
address) to a "host object" that stores information about all 
traffic to or from that host. Each Host object maintains 
aggregate traffic statistics for the associated host. 
5 The details of one or more embodiments of the invention are 

set forth in the accompanying drawings and the description 
below. Other features, objects, and advantages of the invention 
will be apparent from the description and drawings, and from the 
claims . 
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BRIEF DESCRIPTION OF THE DRAWINGS 
FIG. 1 is a block diagram of a network including anomaly 
detection. 

FIG. 2 is a block diagram depicting exemplary details of 
5 anomaly detection. 

FIG. 2A is a flow chart of a process to identify client 
server pairs. 

FIG. 3 is a block diagram depicting an aggregator. 
FIG. 4 is a block diagram depicting a connection table. 
10 FIG. 4A is a block diagram of an alternative connection 

table . 

FIG. 5 is a block diagram depicting a record in the 
connection table. 

FIG. 6 is a block diagram depicting an arrangement of 
15 connection tables. 

FIG. 7 is a block diagram depicting a clustered aggregator. 
FIG. 8 is a flow chart of processes on the aggregator. 
FIG. 9 is a flow chart depicting a generalized process for 
detection of anomalies and classification of events. 
20 FIG. 10 is a flow chart depicting event processing. 

FIG. 11 is a flow chart depicting denial of service attack 
processing. 

FIG. 12 is a flow chart depicting details of denial of 
service attack processing. 
25 FIG. 13 is a flow chart depicting scanning detection. 

FIG. 14 is a flow chart depicting worm detection 
FIG. 15 is a diagram depicting worm propagation. 
FIG. 16 is a flow chart of an unauthorized access detection 
process . 

30 FIG. 17 is a flow chart of a new host detection process. 

FIG. 18 is a flow chart of a failed host detection process. 
FIG. 19 is a block diagram of a network. 
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FIG. 20 is a diagram depicting a grouping. 

FIG. 21 is a flow chart depicting a grouping process. 

FIG. 22 is a flow chart depicting a group forming process. 

FIG. 23 is a flow chart depicting details of the group 
forming process. 

FIG. 24 is a diagram depicting a stage in grouping nodes. 

FIG. 25 is a flow chart depicting details of a group 
merging process. 

FIGS. 26-28 are flow charts depicting details of a group 

correlation process. 

FIGS. 29-30 depict screens in a feedback mechanism. 
FIG. 31 depicts a flow chart in a feedback mechanism. 
FIGS. 32-36 depicts screens for reports. 
FIGS. 37-40 depicts screens for settings. 

DETAILED DESCRIPTION 
Referring to FIG. 1, an anomaly detection system 10 to 
detect anomalies and process anomalies into events is shown. 
The anomaly detection system 10 can be used to detect denial of 
service attacks (DoS attacks), unauthorized access attempts, 
scanning attacks, worm propagation, network failures, and 
addition of new hosts in a network 18. The system 10 includes 
collector devices 12 and at least one aggregator device 14 and 
an operator console 16 that communicates with and can control 
collector devices 12 and the at least one aggregator device 14. 
The collector devices 12 and the at least one aggregator 14 are 
disposed in the network 18. The collector devices 12 connect to 
network devices, 15 e.g., switches, hosts, routers, etc. in 
line, or via a tap, e.g., using mirror, SPAN ports or other 
passive link taps. The collector devices 12 collect information 
such as source and destination addresses, transport protocol, 
source and destination ports, flags, and length. Periodically, 
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the collector devices 12 send to the aggregator 14 a record of 
the number of packets, bytes, and connections between every host 
pair observed by the collector 12, broken down by port and 
protocol. In addition, the collector devices 12 send summary 
5 information concerning flags seen on TCP packets. 

The aggregator 14 can also execute a grouping process 200 
that efficiently partitions hosts on a network into groups in a 
way that exposes the logical structure of the network 18. The 
grouping process 200 assigns nodes to groups and includes a 

10 classification process 200a that classifies hosts by groups and 
a correlation process 200b that correlates groups. Details of 
the grouping process are discussed below. 

Referring to FIG. 2, collectors 12 are shown disposed to 
sample or collect information from network devices 15, e.g., 

15 switches as shown. The collector devices 12 send the 

information to the aggregator 14 over the network 18. The 
collectors 12 in one configuration sample all traffic from a 
downstream network 19a provided that the traffic traverses the 
switches 15, whereas in another configuration the collectors 12 

20 sample traffic from downstream network 19b that enters and 
leaves the switches 15. 

The architecture is based on an examination of current 
bytes/second, packets/second, connections/hour statistics, and 
so forth. The architecture compares these to historical data. 

25 The data collectors are devices that are coupled actively or 

passively on a link and collect the above mentioned as well as 
other statistics. Data collects 12 can be connected via a tap 
or can span port on a monitored device (e.g., router, etc.) over 
intervals of time. Over such intervals of time, e.g., every 30 

30 seconds, the data collectors 12 send reports (not shown) to an 
aggregator. The report can be sent from the data collector to 
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the aggregator over the network being monitored or over a 
hardened network (not shown) . 

There are a defined number of sources, a defined number of 
destinations, and a defined number of protocols on a given 
5 network. Over a defined interval (typically 30 seconds) , the 

data collectors 12 monitor all connections between all pairs of 
hosts and destinations using any of the defined protocols. At 
the end of each interval, these statistics are summarized and 
reported to the aggregator 14. The values of the collected 

10 statistics are reset in the data collectors after reporting. 
The number of connections between ports using an unknown 
protocol is also monitored. 

If more than one data collector saw the same source and 
destination communicating, the following could have occurred. 

15 The data collectors could be in parallel and each saw a portion 
of the communication. Alternatively, the data collectors could 
be in series and both data collectors saw the entire 
communication. Given the rate at which parallel connections may 
change, the aggregator assumes that the data collectors are in a 

20 series connection. The maximum of two received values is taken 
as a value for the connection and it is assumed that the lower 
value reflects dropped packets. Other arrangements are 
possible . 

Referring to FIG. 2A, an aspect of data collection 22 on 
25 the collectors 12 is shown. Data collection is used to collect 
connection information to identify host connection pairs. Data 
collection uses heuristics to identify connections such as host 
A sending packets to host B, host B sending packets to host A. 
In addition, the data collection 22 determines host A c i ie nt host 
30 B serve r and host B c iient and host A server . To determine when hosts A 
and B are operating as clients or servers, data collection 
process determines 23a the protocol used in a connection. If 
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the protocol is TCP, then the process identifies 23b, which host 
sent a sync packet, and which host sent a synch_ack packet. The 
source of the sync packet is the client and the source of the 
synch_ack is the server. 
5 If the protocol is not TCP, e.g., UDP, the data collectors 

12 will determine the ports that the hosts communicate over. If 
the hosts are transacting over a well-know port 23c, the data 
collector will examine a list of well-know ports. The list will 
determine 23d the source of the server from the list. The list 
10 is populated with identifications of hosts and is populated by a 
process that looks at previous sources of synch_ack packets. 
The host that sends the synch_ack packet back is assumed to be 
the server. 

If a connection involves two ports, neither of which is 

15 known 23e, then the process will assume that the host that 
connects to the lower port number is the server process. 

The host server /client statistics are useful in anomaly 
detection. For instance, these statistics are useful when 
attempting to identify worm intrusions and other types of 

20 intrusions. 

Referring to FIG. 3, the aggregator 14 is a device (a 
general depiction of a general purpose computing device is 
shown) that includes a processor 30 and memory 32 and storage 
34. Other implementations such as Application Specific 

25 Integrated Circuits are possible. The aggregator 14 includes a 
process 36 to collect data from collectors 12 and a process 38 
to produce a connection table 40. In addition, the aggregator 
includes anomaly analysis and event process 39 to detect 
anomalies and process anomalies into events that are reported to 

30 the operator console or cause the system 10 to take action in 
the network 18. Anomalies in the connection table can be 
identified as events including denial of service attacks, 
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unauthorized access attempts, scanning attacks, worm 
propagation, network failures, addition of new hosts, and so 
forth. 

Referring to FIG. 4, the connection table 40 is a data 
5 structure that maps each host (e.g., identified by IP address) 
to a "host object" that stores information about all traffic to 
or from that host. In one implementation of the table, source 
address is one dimension, destination is a second dimension and 
time is a third dimension. The time dimension allows a current 

10 record and historical records to be maintained. 

Using IP addresses to uniquely identify hosts could be 
inadequate in environments with dynamic DHCP assignments. Thus 
alternatively, the administrator can configure a DHCP server to 
produce a MAC address to IP address map. The MAC address to IP 

15 address map is sent as a flat file to the aggregator 14. 

Thereafter, when a data collector 12 reports an IP address and 
counter to/from values, the aggregator 14, for each IP address 
checks in the most recent map. If the IP address is found in 
the map, then the host is managed by a DHCP server and the host 

20 ID is the host's MAC address, otherwise the Host ID is the host 
IP address. 

The host object, e.g., 40a of a host "A" also maps any host 
(IP address) "B" with which "A" communicates to a "host pair 
record" that has information about all the traffic from "A" to 

25 "B" and "B" to "A". This two-level map enables the system 10 to 
efficiently obtain summary information about one host and about 
the traffic between any pair of hosts, in either direction. 

Hashing is used to "lookup or update" information about any 
host or host pair on the network 18. The connection table 40 

30 includes additional structure to allow efficient traversal of 

all hosts or host pairs and supports efficient representation of 
groups of related hosts, e.g., a role grouping mechanism as 
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discussed below. Alternatively, the role grouping can be stored 
separately from the connection table. 

The connection table uses a hash map from host identifiers 
(IP or MAC addresses) to "Host" objects, as discussed. Each 
5 Host object maintains aggregate traffic statistics for the 
associated host ("H"), and a hash map (a 2nd level hash map) 
from host identifiers (IP addresses) of peers of host H (i.e., 
hosts that host H had communicated with) as "HostPair" objects. 
Each HostPair object maintains traffic statistics for each pair 

10 of hosts (H and H' s peer). To allow more efficient, analysis 
HostPair objects are duplicated across Host objects. For 
instance, the HostPair "AB" is maintained both in the hash map 
within Host "A" and in the hash map within Host "B." Group 
information is embedded in the connection table, with each Host 

15 object storing information about the group that the associated 
host belonged to. The connection table maintains a list of all 
groups and their member hosts. 

Referring to FIG. 4A, in an alternative implementation 41 
of the connection table 40, the connection table 41 is split 

20 into two hash maps 41a and 41b, a "host hash" map 41a and a 
"host pair" hash map 41b. The "host hash" map 41a maps host 
identifiers (IP or MAC addresses) to new Host objects 43. Each 
new Host object 43 has the aggregate traffic statistics for the 
associated host, as well as a list of the host identifiers (IP 

25 or MAC addresses) of all the peers of that host 44. The "host 
pair" hash map 41b maps pairs of host identifiers to Host Pair 
objects 45 that maintain traffic statistics 46 for pairs of 
hosts. In this implementation Host Pair objects 45 need not be 
longer duplicated, as discussed above. 

30 For example, if host A and host B communicate, then the 

host map has a Host object 43 for A that lists B as a peer, the 
host map has a Host object 43 for B that lists A as a peer, and 
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the host pair map has a Host Pair object 45 for AB. Group 
information is stored in a separate table 47 that is loaded, 
saved, and otherwise managed separately from the traffic 
statistics in the connection table. It does not need to be in 
5 memory unless it is actually needed. 

Factoring out the group information and moving from many 
hash, maps (top level map, plus one 2nd level map per Host 
object) to just two makes this implementation of the connection 
table more compact and decreases memory fragmentation, improving 

10 aggregator performance and scalability. 

In one embodiment, only "internal hosts'' (defined based on 
configurable IP address ranges) are tracked individually as 
described above. The aggregator 14 buckets all other 
("external") hosts into a fixed number of bins according to 8- ■ 

15 or 16-bit CIDR (Classless Inter-domain Routing) prefix. This 
approach preserves memory and computational resources for 
monitoring of the internal network 18 but still provides some 
information about outside traffic. Other arrangements are 
possible, for instance bucketing can be turned off if desired, 

20 so that each external host is tracked individually. 

Referring to FIG. 5, exemplary contents of the host object 
40a are depicted. Similar statistics can be collected for host 
objects 43. As shown, the contents of the host object 40a in 
the connection table 4 0 include a measure of the number of 

25 bytes, packets, and connections that occurred between hosts 
during a given time-period, here on a daily basis. Data is 
broken down per-protocol for every well-known transport protocol 
(e.g., TCP, UDP, ICMP, and the 132 others defined by the 
"Internet Assigned Numbers Authority" and for several hundred 

30 well-known application-level protocols (e.g., SSH, HTTP, DNS, 
and so forth) . For every application-level protocol, and for 
every pair of hosts "A" and "B", the Connection Table stores 
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statistics for traffic from host A to host B and from host B to 
host A both for the case where "A" is the server and the case 
where "B" is the server. Unknown protocols are counted together.' 
Since most hosts only use a small fraction of the well- 
5 known protocols, the footprint of the data structure is kept 
manageable by storing protocol-specific records as (protocol, 
count) key-value pairs. Further, since the protocol 
distribution is typically skewed (a few protocols account for 
the majority of traffic on each host), key-value pairs are 
10 periodically sorted by frequency to improve amortized update 
time . 

Individual host records have no specific memory limit. If 
a particular host connects with many other hosts and uses many 
protocols, all that information will be recorded. However, the 

15 total memory used by the Aggregator 14 is bounded in order to 
avoid denial of service attacks on the Aggregator 14. For 
example, an attacker spoofing random addresses can cause the 
Aggregator 14 to allocate new host structures and quickly 
consume memory. If an Aggregator ever exceeds a memory 

20 utilization threshold "m_{hi}", it de-allocates records until 

its memory utilization falls below "m_{hi}". Several different 
algorithms can be used for picking records to de-allocate. Some 
of the algorithms that can be used include random eviction, 
picking low-connectivity hosts first, high-connectivity hosts 

25 first, and most recently added hosts first. Similar measures 
are also taken on the probes 12 to ensure high performance and 
limit Probe-Aggregator communication overhead. 

Referring to FIG. 6, the aggregator 14 uses different 
connection tables 40 to track data at different time scales. A 

30 first connection table 49a is a time-slice connection table that 
operates on the smallest unit of time, e.g., (a time-slice}. A 
time-slice can be e.g., less than 30 seconds to maybe several 
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minutes. The time-slice connection table is the sum of records 
received from all collectors during that the time-slice period, 
corrected for duplicates. 

Aggregator analysis algorithms 39 operate primarily on a 
5 short update period (SUP} Connection Table 49b, which is the sum 
of time-slices across a period of, e.g., 10 to 30 minutes. A set 
of SUP connection tables is summed into a third connection table 
49c covering a long update period (LUP) , e.g., 2 to 24 hours. 
For each recorded parameter (such as TCP bytes from host "A" to 

10 host U B"), SUP and LUP tables track both the sum and sum of 

squares of values of the recorded parameter. These two values 
allow the aggregator to compute both the mean and variance of 
the recorded parameter across the table's time period. Given 
"N" samples x lf X2,~. x n mean is sum over the period of the 

15 samples divided by the number of samples. The variance is 
derived from the mean and sum of squares. 

At the end of each long update period, that period's values 
are merged into a profile connection table that includes 
historical information for the corresponding period of the week. 

20 Merging uses the equation below for each value in the profile 
table. For instance, a LUP table covering the period 12pm to 
6pm on a Monday is merged into a profile table with historical 
information about Mondays 12pm to 6pm. Values in the profile 
table are stored as exponentially weighted moving averages 

25 (EWMAs) . At time "t", a new value "x t " (from the LUP table, for 
example) is added to the EWMA for time "t-1", denoted by "m t -i", 
to generate a new EWMA value according to the following 
Equation : 



30 
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where a can be tuned to trade off responsiveness to new 
values against old ones. EWMAs provide a concise way of 
representing historical data (both values and variance) and 
adapting to gradual trends. Recent data is compared to 
5 historical profiles from the same time of, an historical time 
span, e.g., a week because the week is the longest time span 
that generally shows well-defined periodicity in traffic 
patterns. By spanning a week, the approach covers diurnal 
cycles and week/weekend cycles. Recurring events with longer 

10 time periods, for example, monthly payroll operations, are less 
likely to show similarly well-defined patterns. 

A collector 12 should handle relatively high rates of 
network traffic. As the network grows and traffic volume 
increases, additional collectors 12 can be deployed in 

15 appropriate locations to tap new network traffic. 

Referring to FIG. 7, factors affecting scalability of the 
Aggregator 14 include the amount of memory consumed by the 
connection tables and the time required for anomaly analysis 
algorithms to traverse the connection tables. As a result, 

20 connection tables can be distributed across multiple physical 
hosts. That is, the aggregator 14 can be configured as a 
cluster of aggregator members 14a-14n, such that the aggregator 
can grow over time to meet additional processing load. Each 
host record and its associated host pair records have enough 

25 information that they can be processed independently by analysis 
algorithms as discussed below. Information about different 
hosts can be dispatched to different cluster members 14a-14n and 
identical sets of algorithms run on all the cluster members 14a- 
14n. Furthermore, individual analysis algorithms can be 

30 implemented as independent threads, in a multiprocessor 
platform. 
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Referring to FIG. 8, the aggregator 14 also includes 
analysis processes 39 to detect network events. Such processes 
39 can include a process 60 to detect bandwidth denial-of- 
service attacks, a process 70 to detect scanning and probing 
5 intrusions, a process 80 to detect worms, a process 90 to detect 
unauthorized access, a process 100 to detect new hosts on the 
network, and a process 110 to detect failure of hosts or 
routers. Other events can also be detected by addition of 
corresponding processes. 
10 Before discussing each of these processes 49 individually, 

it is useful to focus on common characteristics of these 
processes 39. 

Referring to FIG. 9, a generic flow process 50 of an event 
detection process is shown. One characteristic of the generic 

15 flow process 50 is that in general the processes are historical 
and profile-driven. The generic flow process 50 tracks 51 a 
moving average that allow processes to adapt to slowly changing 
network conditions without user intervention. The generic flow 
process 50 also tracks 52 a variance of a parameter to allow the 

20 generic flow process 50 to account for burstiness in network 

traffic. Several of the algorithms can optionally be tuned via 
constants to alter parameters such as sensitivity. Historical 
analysis minimizes the amount of tuning that needs to be done. 
The benefits of historical analysis, therefore, are to decrease 

25 management complexity while improving analysis quality. 

The generic flow process 50 operates at two conceptual 
levels, anomalies and events. The generic flow process 50 finds 
53 anomalies, i.e., low-level discrepancies in the network, 
e.g., a host is receiving unusually high traffic, for example. 

30 Conventional intrusion detection would tend to report anomalies 
directly to the operator. This can be a problem because a 
single intrusion may correspond to many anomalies, and many 
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anomalies are benign. In contrast, the system 10 using 
aggregator 14 collects anomalies into events 54. The operator 
is sent 55 event reports giving the operator more concise and 
useful information, while simplifying system management. 
5 Referring to FIG. 10, processes 39 handle events, i.e., 

high-level occurrences that have significance to a network 
administrator. The processes 39 distinguish among different 
classes of events. A general flow 56 that can underlie some of 
the processes 39, discover events by traversing 56a the 

10 connection table 40 and identifying 56b and correlating 

anomalies. From correlated anomalies events are produced 56c. 
For example, a DoS attack event may be identified because of an 
abnormal high level of traffic destined to some set of hosts. 
The generic flow process 50 examines connection patterns rather 

15 than packet signatures. Connection patterns can be more 
strongly correlated with a particular event. 

Consider a worm. The presence of a worm, such as the NIMDA 
worm on a network may not be a threat if all hosts have been 
patched for NIMDA, but those packets will nonetheless generate 

20 reports (and potential false positives) from typical intrusion 
detection. Rather, a tree-like pattern of connections is much 
more definite proof that an actual worm infection is occurring. 
In order to decrease false positives, processes 39 look for more 
reliable evidence of suspicious activity, e.g., determine 

25 whether observed anomalies produce events and report the events 
rather than mere anomalies. The processes 39 determine 56d 
event severity as functions of the types, numbers, and 
severities of anomalies that led to the identification of the 
event. Events can be sorted by severity, of course, further 

30 simplifying management of the network. The processes 39 report 
56e the event. 
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Denial of Service Attacks 

Denial of service (DoS) attacks attempt to overload a 
victim server's resources by sending the victim more data than 
it can handle, e.g., a large number of packets or a high byte 
rate or both. In addition, some DoS attacks will randomly spoof 
source addresses so as to avoid detection, and to confuse any 
DoS detection tools that may be in place to protect the server. 

Referring to FIG. 11, denial of service detection process 
60 detects bandwidth attacks against a host. The denial of 
service detection process 60 examines 62 both packet count and 
byte count to determine 63 whether a host is a potential DoS 
victim. In addition, if a host is determined to be a potential 
victim, the denial of service detection process 60 iterates 64 
over all connected hosts to determine which hosts are possible 
attackers . 

Referring to FIG. 12, to determine 63 whether a host "H" is 
a victim of a DoS attack, the process 60 determines 63a whether 
or not the host has a historically high variance in inbound 
packet rate. If the host does not have a high variance the 
process compares 63b the current measured inbound byte rate with 
"H's" historical average inbound byte rate for the current 
profiled time period. However, if a host has a large variance 
63b in inbound packet and byte rate, the process avoids 
triggering an alert merely based on byte rate, but rather the 
process 60 uses 63c a stored profiled variance, as follows. 

Let "a 2 " be the variance of "H's" inbound byte rate, stored 
in the appropriate profile connection table. Then "a" is equal 
to one standard deviation. Let "c" be "H' s" current incoming 
byte rate and "h" be "H' s" historical average incoming byte 
rate. If the inequality (c > (h + CI * <r) * C2) is true, then 
process can consider the host H to under a possible DoS attack. 
To decrease the overhead associated with computing square roots, 

- 17- 



Patent Application 

Attorney Docket No. 1 222 1 -02500 1 

the process can calculate this in two passes. The first pass 
determines if "c > h * C2" . If this is true, the process 
calculates the standard deviation, and uses it as shown. 
Otherwise, the process can conclude that the inequality that 
5 considers standard deviation will also be false, and can skip 
the complete calculation. "CI 7 ' and "C2" are tunable constants. 
Exemplary values are "CI = 2" and "C2 = 2 . " Thus, in either 
case the process determines 63d if the parameter (variance or 
byte rate exceeds a historical amount. 

10 In addition, the process 60 determines 63e if incoming 

packet count is above a certain threshold, to filter out new or 
low-traffic hosts that suddenly receive a low but still larger 
than normal amount of traffic. A value of, e.g., 500 to 2000, 
nominally 1000 packets per second is a reasonable number for 

15 this lower bound. 

If these conditions are satisfied, then the process 60 
increases 63f the severity of the reported event. The process 
60 reports 63g the event to the operator (to reflect a high 
degree of certainty that this is an DOS attack) . The process 60 

20 applies a similar inequality to incoming packet rates. 

Other factors that influence whether the event is a DoS 
attack include whether the suspected victim is receiving traffic 
from an unusually (relative to historical profile) large number 
of other hosts, a typical indication of a broadly spoofed 

25 attack. Another factor is whether most of the hosts connecting 
to the suspected victim do not exist in the profile connection 
table, almost certainly an indication of a spoofed attack. 
Another factor is whether most of the new traffic to the host is 
UDP, ICMP, or unknown protocols. Again, this is further proof 

30 to corroborate the symptoms of a typical bandwidth DoS attack. 

All or some of these can be used to elevate the severity of the 
event . 
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Once a host is determined to be a DoS victim, the process 
42 examines the host's neighbors to determine which hosts are 
possible attackers. For each neighbor U H_{0}" of "H", the 
process determines the byte rate from "H_{0}" to "H" . Let 
5 "c_{0}" be the current byte rate from "H_{0}" to "H", "h_{0}" 
the historical average byte rate from "H_{0}" to W H" , and 
"g 2 _{0}" the variance of the byte rate from "H" to "H_{0}." If 
an inequality holds 

c_{0} > (h_{0} + CI * c?_{0}) * C2 

10 then "H_{0}" is a suspected attacker of "H". 

The constants "CI" and "C2" can be the same as above. The 
process also examines the packet rates from "H_{0}" to "H" in a 
similar way. 

Since a spoofed source address DoS attack could have 

15 hundreds or even thousands of different source addresses, the 
process 60 can cap the number of source addresses that are 
reported. A reasonable number for the cap is 1000 addresses. If 
the cap is reached, process raises the severity of the attack 
reported, as noted above. 

20 This approach to DoS detection differs from that of other 

techniques used in intrusion detection systems (IDSs) in several 
ways. For instance this process 60 measures usual network 
activity at a per-host level, and bases attack detection on 
proportional violations of those usual levels. This avoids the 

25 need for user-determined thresholds as is common in conventional 
IDS. Incorrect thresholds cause false positives and major 
operator costs in practice. Moreover the inclusion of variance 
in the formula reduces false positives based on network 
burstiness. "Burstiness" is another user-determined threshold 

30 in conventional intrusion detection systems. Since the "attack 
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threshold" is measured per host, the process 60 automatically 
adapts to different server capacities. That is, if a server XN A" 
usually handles a small fraction of server B ! s traffic, then a 
small attack on server A will cause an event, where that attack 
5 might be (properly) left in the noise on server B. 



Pnocrcnums DoSDrtkctton (ho«t. H) { 

avjvpL < Hs current average incoming pps 
hfr-pl < H : s historical araratfe incoming ppp 
var.pL <■ - variance of H's incoming pps 
avE-bL H s current average incoming bps 
his bl < H : s historical average incoming hps 
var.bL <■ - variance of H's incoming bps 

if (avR-p I < Cl ) 
return false 

if (avRjpl < (his_pl \ C2 * y/tw .pl ) » C 3 

and avp_bl < (his_bl ■+■ C2 ■* >/var_6i) * C3) 
return false 

for e^eh licet HO connecter] to H 

avg_p2 <- current, average pps from HQ to H 
his_i>'2 < ■ historical average pps from HO to K 
var..p2 variance of pps from HO to H 
avgj>2 < current, average bps from HQ to H 
his_b2 *— historical average bps from HO to H 
var_b2 <• ■ variance of bps from HO l.o H 

if (av£..p2 > {his..p2 r C2 * y/va r p2) * C3 
or avg_b2 > (hisJ>2 < C2 * Vvnr-b2) ¥ C3) 
arid H2 to list of attackers 

return true 

1 



Exemplary pseudo code for detecting denial of service 
attacks and determining the host that is attacking is shown 
above . 



Scanning and Probing Intrusions 
10 A network scan is a probe by which an attacker learns more 

about computers on a network and their vulnerabilities. Scans 
are often caused by intruders trying to gain access, and may be 
done manually or automatically by an active worm. Two types of 
scans are ping scans and port scans. A ping scan detects the 
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existence of hosts on a network, while a port scan detects which 
services are running on a particular host. 

The purpose of a ping scan is to determine the IP addresses 
of other networked hosts. Packets are sent to many different IP 
addresses, and hosts that are up respond. A ping scan may use 
ICMP, TCP, or other protocols. It may iterate over a set of 
addresses, such as all addresses in a subnet or it may test many 
random addresses. 

Referring to FIG . 13, the scan detect process 70 tracks 
ping scans with an application of the connection table 40. Each 
time a host scans another host, a host pair record is added 71 
to the current time slice connection table. At the end of each 
short update period 72, the scan detect process 70 accesses 73 
the time slice connection table 41 to determine 74 new host 
pairs that the process had not determined before in the profile. 
The scan detect process 70 sums 75 the number of new host pairs 
determined and determines 76 if a host has made more than U C3" 
new host pairs. The process 70 checks if the number of 
historical host pairs in the profile is smaller 77 by a factor 
of "C4." If the historical number is smaller by the factor C4, 
the host is flagged 78 as a scanner. The constants "C3" and 
"C4" are adjustable thresholds. This will catch most ping scans 
since typically a ping scan will scan many hosts in a short 
time . 

Stealthy ping scans ping the network slowly in order to 
avoid detection. Because a stealthy scan moves so slowly, the 
system 10 will produce only a few new host pair records in each 
SUP. Over time, the scan will still produce many new host 
pairs. The scan process 70 also checks for ping scans at the 
end of each long update period, flagging stealthy ping scans 
which produced more than "C5" new host pairs over the long 
update period. Thus, the scan detect process 70 detects 
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stealthy ping scans in a reasonable amount of time, although 
detection does not occur as quickly as with normal ping scans. 
Essentially, for stealthy scans the process increases the 
reporting delay in order to decrease false positives. 
5 Compared with traditional IDS systems, the scan detect 

process 70 has several advantages. Traditional IDS systems rely 
on heuristics that could be easily misled, such as looking for 
incremental IP addresses. Because the history of each host's 
network traffic is maintained in the connection tables, the scan 

10 detect process 70 will not incorrectly declare scans during 

normal traffic. An IDS that only detects signatures will not be 
able to distinguish scans from scan-like normal operations. The 
scan detect process 70 distinguishes normal host 
interconnections from abnormal ones, so a scan coming . from a 

15 typically active host will still be detected, since the scan 
would produce new host inter-connections. 

The scan detect process 70 also detects stealthy scans by 
looking at the activity of each host over a longer period of 
time. The scan detection process 70 thus examines host activity 

20 over a sufficiently long enough period of time to detect 

stealthy scans. The scan detect process does not consider the 
packet type in detecting scans. The scan may use ICMP packets, 
TCP packets, another protocol, or some combination. Rather, the 
scan detect process 70 will detect that the scanning host has 

25 initiated network communication with an unusual number of hosts. 

A possible extension is to maintain ARP (Address Resolution 
Protocol) packet statistics to detect ping scans. Ping scans 
often produce a large number of ARP requests. If the scanner 
scans a dense subnet on which there are many hosts, the number 

30 of ARP requests will be similar to the number of successful 

''connections." However, for sparse subnets the host may fail to 
route many of its packets to their intended destination. In 
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this case it will generate a high level of ARP requests that do 
not receive responses, and for which the new host will not 
produce follow-on IP packets. Keeping track of ARP packets 
would allow the scan detect process 70 to detect scans more 
quickly and accurately on sparse networks. 

Port Scans 

A port scan determines which ports are listening on a known 
host, indicating which services are running (port 80 indicates 
HTTP, port 22 indicates SSH, etc) . Port scans use either TCP or 
UDP protocols. 

Port scans may scan all "2 16 " ports or they may only scan a 
few interesting ports. Port scans may use a variety of 
different packet types, sizes and flags to try to avoid 
detection. However, port scans send packets to many different 
ports, so ports scans can be detected with the connection table 
40. 

As discussed, the connection table 40 stores records that 
have data on protocols and ports used for each host pair. If 
the number of ports used in the historical profile is 
considerably smaller (e.g., by a factor "C5") than the current 
number of ports, and the current number is greater than some 
lower-bound threshold ("C6") , then the aggregator 14 will record 
the anomaly and report a port scan. The reported severity 
varies as a function of the deviation from historical norm. 

The port scan detection process examines connection-based 
features of an anomaly rather than attempting to ascertain and 
develop a signature for a potential attack. The port scan 
detection process knows which ports hosts communicate with, so 
it is unlikely that the port scan detection process would 
declare a port scan for normal traffic. The port scan detection 
process does not examine the actual structure of the packets. 

-23- 



Patent Application 

Attorney Docket No. 12221-025001 

Therefore, a scan may set any combination of TCP flags and the 
port scan detection process will still recognize it as a port 
scan . 

Because the aggregator 14 examines data collected over a 
5 long period of time, it will detect stealthy scans which are too 
slow for some conventional IDS systems to recognize. 

An extension of the scan process 70 is to use the 
connection table statistics about TCP RST packets and ICMP port- 
unreachable packets. Hosts respond to "failed" TCP probes with 

10 RST packets, and to "failed" UDP probes with ICMP port- 
unreachable packets. A spike in the number of these packets 
relative to the historical norms could be used to increase the 
severity of a port scan event. As with ping scans, the scan 
process 70 checks for port scans at the end of each short update 

15 period and each long update period. Normal scans will be 

quickly caught at the end of the current SUP. Stealthy scans 
will avoid immediate detection but will be caught later at the 
end of the long update period (LUP) . 

Worm Detection 

20 Worms are programs that exploit weaknesses in network 

services to copy themselves to other computers and spread. They 
typically use ping scans to find new computers to infect. Some 
worms are so aggressive that they generate high levels of 
network traffic and cause denial of service attack side effects. 

25 A worm's activity looks like a ping scan to the process 42. 

The presence of several ping scans from different hosts in a 
short time is reason to suspect the presence of a worm on those 
machines . 

Referring to FIG. 14, the worm detection process 80 
30 retrieves 82 from the connection table 40 information about 

effects in the network 18 caused by the worm, including the path 
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by which it spread and the services that it is exploiting. The 
worm detection process 80 examines 83 the host pairs in the scan 
and reconstructs 84 the path by which the worm spread. The worm 
detection process 80 examines 85 the ports used by the worm and 
5 determines 86 which services were exploited. 

For example, consider the situation in FIG. 15, which 
represents that scans were detected emanating from hosts "A", 
"B", and "C." 

FIG. 15 shows that in time period "ti", host "A" scanned 

10 host "ai", at time "t 2 ", host "B" scanned "bi", and at "t 3 " , host 
"C" scanned "ci." Since, "B = a 2 ", and "C = b 6 ", the worm 
detection process determines that a worm has passed from "A" to 
"B" at time "ti", and from "B" to "C" at time "t 2 ". The worm 
detection process also determines that "A" connected to "B" 

15 through port 80, and that M B" connected to W C" through port 25, 
indicating which services are vulnerable. 

Assume that hosts "A", M B", and "C" were all flagged for 
ping scans in time periods "t a ", "t b ", and "t c " respectively, 
with xx t a being less than or equal to t c " . The worm detection 

20 process 80 analyzes the scan anomalies for the sets of hosts 

"S a ", "S b ", and >V S C " that hosts "A" "B" and "C w scanned. If host 
"B" is in "S a ", and host "C" is in ^Sb", then the worm detection 
process determines that the worm spread from host "A" to host 
"B" to host "C." The worm detection process 80 examines which 

25 port host "A" used to connect to host "B", and which port host 

"B" used to connect to host "C." The process 80 also determines 
the vulnerable services on each of those hosts. These could be 
different ports for worms that have the ability to exploit 
multiple services . 

30 It is possible for a worm to be stealthy by having the worm 

only connect to hosts that an infected host normally connects 
to. Or, if the worm has root access, the worm may listen to the 
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network and discover more hosts. There are no common worms of 
this form. Also, such a worm could have difficulty spreading 
since it might not come into contact with many vulnerable hosts. 
Still, the worm detection process 80 could detect such worms by 
5 scanning for unauthorized access anomalies (as discussed below) 
and connecting the unauthorized access anomalies into a path as 
it does with scan anomalies. 

Unauthorized access 

Unauthorized access events occur when one machine makes an 

10 attempt to connect to a machine to which it would not normally 
connect. An example of such an event is a host normally used 
for engineering research connecting to a server used in a 
personnel department . 

Referring to FIG. 16, an unauthorized access attempt 

15 detection process 90 is shown. The unauthorized access attempt 
detection process 90 obtains 92 connection pairs for a host that 
is attempting to gain access to another host from the connection 
table 40. The unauthorized access attempt detection process 90 
determines 94 whether that one host attempting to gain access 

20 has accessed the other host previously. If the host has 

accessed the other host previously, the process 90 does not 
raise any events and merely continues to monitor accesses. 

If that one host has not accessed the other host, the 
unauthorized detection process 90 will determine 96 if other 

25 anomalies in the connection patterns of each host exist in order 
to determine how likely it is that this is an instance of 
unauthorized access. 

Heuristics can be used to increase 96 the severity of a 
possible unauthorized access event. For example, one heuristic 

30 is that connection patterns indicate that the hosts are in roles 
that are not normal for those hosts. For instance, in the 
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example mentioned above, engineering hosts do not commonly 
access the personnel server host. Thus, if an engineering host 
connects to the personnel server, it could indicate that an 
unauthorized access is being attempted. Another indication is 
5 that connection requests use the transport control protocol 
(TCP) . Use of TCP could indicate that someone is trying to 
access the host to gain or modify sensitive data as TCP is the 
protocol that is usually used to transfer data. Another 
indication is that the connections use ports that are not well 

10 known (i.e., not used for a common service), indicating a 

possible Trojan-type virus. Also, if the connections use ports 
that have not been used before, that could indicate an 
unauthorized access attempt. Another indicator is if several 
short connections occur in a short time period (possibly 

15 indicative of failed logins) . Each of these patterns of 

connection behavior between two hosts can be determined from 
examination of connection patterns by analyzing data from the 
connection table 40. 

Conversely, there are a few rules that will decrease 98 a 

20 likely event severity or make a potential event a non-event. 
One rule is that the hosts are in roles that commonly access 
each other's hosts. Another rule that can decrease severity is 
that the host being connected to commonly receives connections 
from new hosts. This may indicate, for example, that it is a 

25 server and new hosts connect to it sporadically. Another 
consideration is that the connecting host commonly makes 
connections to new hosts. This could indicate that the host is 
relatively new, i.e., the new host has appeared on the network 
recently. In this case, the process 40 will not know the 

30 connection habits of the new host. If an event is still 

indicated, the process 90 will send or raise 99 an event with 
the proper level of severity to the operator. 
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The unauthorized access detection 90 uses role grouping or 
role classification. In the example above, hosts in the 
engineering department frequently make connections to machines 
in a lab. Although all engineering hosts probably do not 
5 connect to all lab machines, individual engineering hosts likely 
would frequently connect to some lab machines. If roles are not 
considered, an engineering host that connects to a lab host for 
the first time may trigger an event. However, the engineering 
hosts will typically be assigned the same role, and lab machines 

10 will be assigned another role. By taking host roles into 

consideration, the unauthorized access detection process 90 
understands that an engineering host connecting to a lab machine 
for the first time is probably not a suspicious event. 

A traditional packet-based IDS has no notion of roles, and 

15 tries to detect intrusions based on packet payloads that it 

detects on a link. This approach can typically generate many 
false positives on a large network. Alternatively, operators 
may be able to explicitly define allowable connections or 
similar policies, but this is a tedious and error-prone process. 

20 Furthermore, since most conventional intrusion detection systems 
are standalone devices deployed on a single link, they may not 
catch access violations happening elsewhere on the network. 

An example of pseudo-code for estimating the likelihood of 
a connection being unauthorized is shown below. Constants C 0 

25 through C n may optionally be tuned to change the weight 
different factors have on the severity. 
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Procedure UNAUTiiomzEDAccBSS (host Hi, H2) { 
badness <~~ 0 

if HI has connection to H2 

if HI has not previously connected to H2 
badness <~~ CO 

if machines in rolb(HI) do not com in only 

access machines hi noi,E(H2) 

badness -f = CI 
if connection protocol = TCP 

badness 4-= C2 
if port on H2 is not well known 

badness C3 
if port on H2 has not been used before 

badness -t= C4 
if connections are short 

badness -h— Go 
if machines in aoLB(Hl) commonly 

access macJiines in ROL£(H2) 

badness -= C6 
if H2 lias many connections 

badness -= C7 
if HI makes many connections 

badness C8 
if UPT1ME(H1) < C9 

badness -= (CO - UPTtME(Hl)) 
(scaled to max CIO) 
if UPTIME(H2) < C9 

badness =- (C9 - uptime(H2)) 
(scaled to max CM) 

return badness 

} 



Detection of New and Failed Hosts 

The process 39 also includes a process 100 that detects 
5 when a new host appears on the monitored network and, 

conversely, a process 110 that detects when a probe (or 
potentially a router or an entire subnet) appears to have 
failed. 

Referring now to FIG. 17, a new host detection process 100 
10 is shown. New host detection process 100 receives statistics 

collected from a host "A." The new host detection process will 
consider Host "A" as a new host if, during a period of T 
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seconds, the Host M A" transmits 102 at least N packets and 
receives 104 at least N packets, and if the Host "A" had never 
106 transmitted and received more than N packets in any previous 
period of duration T. If these tests are met the Host A is 
5 indicated 108 as a new host. The emphasis on both transmission 
and receipt of packets, and the minimal rate of N/T 
packets/second, attempts to avoid false positives caused by 
scans or spoofing (e.g., reporting a "new host" when in reality 
the system detected a packet that was sent to a non-existent 

10 host as a result of a scan. 

The "new host" detection process 100 detects and notifies 
when any host "H" has a minimal threshold amount of 
receive/transmit traffic no prior history of traffic in the 
network 18. The process notifies the operator of a new host in 

15 the network. 

FAILED HOST DETECTION 

Referring to FIG. 18, a failed host detection process 110 
is shown. A Host "A" becomes a "candidate" for a failed host 
analysis if both a mean profiled rate of server response packets 

20 from the Host "A" is greater than M 112, and the ratio of 

(standard deviation of profiled rate of server response packets 
from the host) to (mean profiled rate of server response packets 
from the host) is less than R 114. That is, the system 10 
analyzes hosts that are uniformly "chatty", e.g., have 

25 relatively high volumes of traffic over regular periods. This 
analysis avoids false positives for quiet hosts, or hosts with 
long periods of inactivity. If these two factors are present 
then the host is flagged as a candidate failed host. 

The failed host analysis determines whether a host 

30 generates more than X server response packets per second in a 
given time slice, and immediately thereafter generates no 
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outgoing traffic for at least S seconds. Failed hosts expire 
(they become "non-existent") after some period D seconds of 
continuous inactivity. The aggregator 14 will generate a new 
host event if a failed host comes back online after this time 
5 has elapsed. 

A host failure can be considered as the inability to 
generate traffic on the network. It can also be applied to 
detect application failures (e.g., an HTTP server crashed). 

10 Grouping 

Referring to FIG. 19, intrusion detection system 10 as in 
FIG. 1 includes collectors 12 and an aggregator 14. System 10 
detects and deals with security violations in large-scale 
enterprise networks 12 including a large plurality of computers 

15 and other devices such as switches, routers, etc, e.g., "hosts" 
20, spread over different geographic locations. The probes 12 
and aggregator 14 operate generally as in FIG. 1. In addition, 
the aggregator 14 executes the grouping process 200 that 
efficiently partitions hosts 20 on the network 18 into groups in 

20 a way that exposes the logical structure of the network 18. 

The grouping process 200 assigns nodes to groups and 
includes a classification process 200a that classifies hosts by 
groups and a correlation process 200b that correlates groups. 
The classification process 200 is based upon analyzing 

25 connection behaviors of hosts and partitions hosts based upon 

the role that the hosts play in the network 18. The correlation 
process 200b correlates the groups produced by different runs of 
the classificat ion process 200b. The two processes 200a, 200b 
form groups of hosts that have a strong degree of similarity in 

30 connection habits and roles in the network. The grouping 
process 200 provides a mechanism to merge groups and gives 
network administrators fine-grained control over merging, so 
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that meaningful results can be provided to an administrator. In 
addition, the grouping process 200 can handle transient changes 
in connection patterns by analyzing profiled data over long 
periods of time. The grouping process 200 responds to non- 
5 transient changes in patterns of communication by producing a 
new partition and provides a useful description of the 
relationship of the new partition to the previous partition. 
Execution of the process 200 reduces the number of logical units 
with which a network administrator deals with, e.g., by one or 

10 two orders of magnitude. 

Referring to FIG. 20, a partitioning of computers into 
groups that the aggregator 14 might produce based on observed 
communication patterns at the probes 12 is shown for the 
enterprise network 18. In FIG. 20, a line indicates that end 

15 nodes communicate regularly and dashed circles represent group 

boundaries. The connection patterns might indicate that Sales-1 
to Sales-N nodes communicate with three servers: Mail server, 
Web server, and Sales Database server. Similarly the patterns 
might indicate that Eng-1 to Eng-M nodes communicate mostly with 

20 Mail server, Web server, and Source Revision Control server. 

Based on this information the grouping process 200 executed on, 
e.g., the aggregator 14 logically divides all the hosts into 
five groups as shown. One group is a sales group having hosts 
Sales-1 to Sales-N, a second group is engineering group having 

25 host Eng-1 to Eng-m. The other groups are a common server group 
having Mail and Web servers, sales server group having Sales 
Database server and engineering server group having Source 
Revision Control server. 

A network manager can label each identified group with 

30 descriptive roles and set policies per group. The grouping 

process 200 continuously monitors communication patterns among 
the hosts and adjusts groups as computers are added and deleted 
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from the network. In addition, the system flags policy 
violations, and raises alerts about potential security 
violations. Because information is presented on the level of 
groups (instead of individual hosts), a network manager is able 
5 to understand and process the changes of the network and alerts 
more easily. 

In FIG. 20 that there are three server groups. The 
grouping process 200 does not necessarily combine the Sales 
Database group with the common server group of Mail and Web 

10 servers. This separation takes into consideration that the 

Sales Database server does not communicate with the hosts in the 
engineering group whereas the Mail and Web servers do. This 
distinction might be important in recognizing an intrusion 
detection event. For example, if a host in the engineering 

15 group were to suddenly start opening connections to the Sales 
Database server it might be a cause for alarm. 

Role classification, or grouping, can be thought of as a 
graph theory problem. From the connection sets of I, role 
grouping generates a neighborhood graph, nbh-graph, where each 

20 node represents a host, and each edge with weight e represents 
that there are e common (one-hop) neighbors between the hosts. 
An undirected graph representation can be used since most 
communications between hosts is bi-directional. 

One approach to the grouping problem is to treat grouping 

25 as a Jc-clique problem where the nbh-graph is partitioned into 

cliques of size k in which each edge in the clique has a weight 
greater than or equal to some constant c. Once a ^-clique is 
identified, all the nodes in the k-clique are assigned to one 
group, since they all share at least c common neighbors. This 

30 approach is problematic, because the Jc-clique problem is NP- 

complete, that is it is solvable in exponential time. Moreover, 
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requiring that all hosts in a group be one-hop neighbors may be 
too strong of a requirement. 

Another approach is to treat grouping as related to the 
problem of identifying bi-connected components (BCCs) . A BCC is 
5 a connected component in which any two edges lie in a simple 

cycle. Hence, to disconnect a BCC, one needs to remove at least 
two edges. Unlike the Jc-clique problem, BCC can be solved in 0(V 
■f E) , where 0 is the order, V and E are the number of nodes and 
edges in the graph respectively. Moreover, all nodes in the BCC 

10 need not be connected to each other directly. However, forming 
groups simply based on similarity measures between host pairs 
may result in a partition that has more groups than desired, 
therefore after execution of a group formation process the 
grouping process executes an process that merges groups with 

15 similar connection habits. 

Referring to FIG. 21, the grouping process 200 has two 
phases a group formation phase 200a and a group-merging phase 
200b. In the group formation phase 200a, the goal is to 
identify groups each of which has one or more hosts with similar 

20 connection habits, and assign a unique integer identifier to 

each group. The group formation phase 200a may end up producing 
a large number of groups. The goal of the second phase 200b is 
to merge group pairs with similar connection habits to form 
larger groups. By merging similar groups, the group merging 

25 phase 200b produces results that more closely match the kind of 
partitioning that system administrators may find useful. The 
group merging phase 200b can be controlled in a fine-grained 
manner by setting the minimum similarity threshold required 
before two groups are merged to form a larger group. 

30 Group Formation 
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Referring to FIG. 22, a group forming process 200a for 
grouping hosts is shown. The group forming process 200a 
produces groups based on observed connection patterns amongst 
the grouped hosts. Hosts as used herein can include computer 
5 systems, as well as other network devices. The grouping process 
200a uses two types of representations of the network, 
connectivity graphs and k-neighborhood graphs. Initially, with 
a connectivity graph, each vertex of the connectivity graphs 
represents a host and an edge between vertices denotes a one-hop 

10 connectivity between corresponding hosts. From this 

connectivity graph, the grouping process constructs 212 a k- 
neighborhood graph. The grouping process 200a identifies 214 
bi-connected components (BCC) in the k-neighborhood graph, and 
assigns 216 a group of nodes in one BCC to a new group. When a 

15 set of hosts is placed into a group, the vertices representing 
those hosts are removed 220 from the connectivity graph and 
replaced 222 by one vertex representing the entire group. There 
are edges connecting the new vertices to each node to which one 
of the hosts in the group was connected. The group forming 

20 process 200a is repeated 224 until the groups are large enough, 
e.g., approach the values of CI. 

Referring to FIG. 23, a detailed implementation 230 of the 
grouping forming process 200a is shown. The group forming 
process 200a generates 232 a connectivity graph, " conn -graph" 

25 based on observed connection patterns between hosts. For k=k max 
down to 1, where k ma x is the maximum number of hosts with which 
a single host communicates the grouping process iterates 233 
over the following until no new groups can be assigned: 

From "conn-graph" the group forming process 200a builds 234 

30 the ^-neighborhood graph "k-nbh-qraph. " The group forming 
process 200a removes 236 group nodes from " Jc-nbh-graph" and 
generates 238 all bi-connected components (BCCs) in "k-nbh- 
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graph." For each BCC the group forming process 200a replaces 240 
in the "conn-graph" the nodes in g by a new group node of those 
nodes . 

The group forming process 200a labels 242 a group "G" by a 
5 pair {IDG, KG), where IDG is a unique identifier and KG is K. 

(KG is used to compute the degree of similarity between groups.) 
For each ungrouped host h, where h < PK (|C(h) | | and 0<PK<1 the 
process produces 244 a new group having only h. 

The group forming process 200a executes iteratively over 
10 the conn-graph until no ungrouped node remains or k=0. Multiple 
bi-connected components (BCCs) may be identified simultaneously 
and a single node could be a part of several BCCs. In this 
case, the node becomes a part of a BCC with the largest size. By 
iterating over k from high to low, the group forming process 
15 200a associates each host h with other hosts with the strongest 
similarity. 

Since a bi-connected component (BCC) is not a clique, e.g., 
a related group, some node pairs in the BCC may not have edges 
between them and thus each of those node pairs does not share at 

20 least k common neighbors. Also any two nodes in the BCC have at 
least two disjoint paths between them. This is not true for the 
BCC with two nodes, which is treated as a special case as 
described above. Thus, the group forming process 200a 
identifies the cluster of nodes in which any two nodes form a 

25 "circular similarity relationship.'' The grouping process 

handles a "bootstrap" situation that could arise in some cases. 

In some situations, the minimum number of nodes required to 
form a BCC is two. In general, the minimum number of nodes to 
form a BCC is 3, since the process does not allow duplicate 

30 edges between any two nodes. However, two isolated nodes that 
are connected by an edge are allowed to form a group. The 
bootstrap problem occurs when there are hosts with a high number 
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of connections, but no two hosts have many connections in 
common. In this situation, the first group will not be formed 
until k is low and the results may not be useful. 

Assume, for example, that the group forming process 200a is 
5 grouping hosts on a small enterprise network with a Windows NT® 
server and a Unix® server. Assume that every non-server host in 
the network communicates with exactly one of the two servers. 
Since the Windows NT® server and the Unix® server are not similar 
to each other, no groups will be formed until k=l . There will 

10 be two resulting groups: one with the Unix® server and those 

hosts communicating with it, and the other with the Windows NT® 
server and the rest of the hosts. To prevent this, for any 
ungrouped host h, if k<Pk* \ C (h) \ , where Pk <Pk the process 
assigns a group, G=(H). In other words, the group forming 

15 process 200a forms a new group with only h members in the group, 
if the process finds any other nodes that do not have the number 
of common neighbors greater than or equal to Pk* C(h). Forming a 
group in this manner encourages BCCs of smaller size. With a 
value of Pk=0 . 6 group forming could work with similar types of 

20 networks. 

Referring to FIG. 24, an example of the group forming 
process 200a for the network depicted in FIG. 20 is illustrated. 
The first group is formed when k = M + N, where M is the number 
of hosts used by sales personnel and N is the number of hosts 

25 used by engineers. For specificity, assume that M = N = 3. As 
shown in the FIG. 24, the 6-nbh graph (6= M+N) has two hosts: 
Mail and Web and the group forming process 200a groups them in 
one group. When k=3, the group forming process 200a identifies 
two additional BCCs, one BCC having all the sales machines and 

30 the other BCC having all of the engineering machines. Because 
of the bootstrap condition, the group forming process 200a 
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produces two groups, one having Sales Database and the other, 
SourceRevisionControl , when K=l < 0.6*M. 



Merging Groups 

5 Referring to FIG. 25, the group merging process 200b merges 

two or more groups with similar connection habits into a single 
group. Group merging can be used to reduce the number of 
groups. Consider the network in FIG. 20 with the modification 
that Sales-1 only communicates with Mail and SalesDatabase 

10 servers. The group forming process 200a produces two groups for 
the sales hosts, one that only has Sales-1 and the other that 
has the rest of the sales hosts. In some situations this is 
undesirable. Using a more sophisticated measure of similarity 
the group merging process 200b builds on the results generated 

15 by the group forming process 32. The group merging process 200b 
merges groups that are similar in connection habits, and 
provides users with the flexibility to have fine-grained control 
over the process so that more meaningful results can be 
achieved. 

20 The group merging process 200b considers two groups to be 

similar if they meet a similarity requirement and a connection 
requirement. The similarity requirement is met if the similarity 
measure between the two groups exceeds user-defined thresholds. 
The connection requirement is met if the average number of 

25 connections of each group is comparable. This requirement keeps 
a group with a large number of connections from merging with 
another group with a much smaller number of connections. 
Although it is possible to incorporate this requirement in a 
single similarity measure, for simplicity, two separate measures 

30 are described. The group-merging process 200b iterates 252 over 
the following actions until no more groups can be merged. 
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For each group pair, (Gl, G2) , that meets 254 the average 
connection requirement and the similarity requirement, the group 
merging process 200b appends 256 a triple (Gl, G2 , s) to a list 
g/ubh-edges, where s- represents the degree of similarity on the 
5 scale of 0 to 100. The group merging process 200b sorts 258 

grubh-edges based on their s - values in descending order. From 
the top triple (Gl, G2 , s) , the grouping process 200a forms 260 
a new group g = Gl U G2, and assigns 2 62 kg to be the minimum 
number of connection pairs a host in G has. The process 200a 
10 clears 264 the gnbh-edges. 

Table 1 
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Procedure MeetConnect!onReq((t l4 <?<>) { 
at <-*£*l*%L : 

> , C{hZ) 

if (al is within Pconn percent of a2) 
return true 

else 

return false 

} 

Procedure M eetS im ila r it y R eq(G i, G<i) { 
kmax maz(Kc % « #a 2 ) 
h <- SlMILARITY(<?| ¥ Git) 
if (k max > K hi and s > 

return true; 
else if (kmax < tf M and s > S**) 

return true 

else 

return false 

} 

Procedure Similarity^. Gi) { 

d <- E fc€ c(Oi) WEIOHT ( (? *) * CP(h t Gi) 

c2 «- r A6 c ( o S ) WEiGHT < c? "> * 

V/»€C(G,)nC(^) 

a «- Weight((?h) * «ittt(CP(fe, Gi) t CPQi, Gn)) 
gs+-s + gs 

return 100 * maz(gs t 0) 

> 



Procedure Weicht(G) { 
} 



Table 1 above depicts pseudo-code for determining the 
5 average connection requirement and the similarity requirement, 
The procedure "MEETCONNECTIONREQ" decides whether the two 
groups, Gl and G2, meet the connection requirement and Gl and 
G2, meet the connection requirement if the average number of 



-40- 



Patent Application 

Attorney Docket No. 1 222 1 -02500 1 

connected host pairs of each group is within Pconn percent of 
each other, where Pconn is between 0 and 1. 

"MEETSIMILARITYREQ" determines whether the two groups meet 
the similarity requirement. Groups Gl and G2 meet the similarity 
5 requirement if the similarity measure between them exceeds the 
user-defined threshold. For the reasons explained shortly, two 
thresholds, Shi. and Slo are used, depending on whether 
max (KG1 ,KG2) >Khi or not. The value "Khi" is a constant that is 
used to determine whether a particular k value is "high." 

10 Recall that kg is the maximum number of one hop common neighbors 
that hosts in G share when forming the group. The values Shi and 
Slo (Shi. > Slo) are the similarity thresholds that can be set 
by the users to control the merging process. The condition 
(Shi. > Slo) is necessary since merging two groups could change 

15 the relations between other groups and may force additional 

merges of groups, which may not be desirable. The effects of a 
group merge depend on the particular groups that are merged and 
how the merged groups relate to other groups. In general, 
merges of groups with high k values could lead to undesirable 

20 results. 

Using the groups in the network in FIG. 20 if N is large, 
the similarity measure between the "SalesDatabase" group and the 
Mail and Web group will be large. Similarly, for large x, the 
"SourceRevisionControl" group will be similar to the Mail and 
25 Web group. If all three groups were to merge, it will 

effectively cause the Sales group and the Engineering group to 
merge, resulting in a partitioning of two groups, one having all 
the servers and the other group having the remainder of the 
hosts . 

30 In most situations such a partition would be undesirable 

since the network administrators lose important separation, 
e.g., between the Sales hosts and the Engineering hosts. For 
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these reasons, groups with high k values are also required to 
have a higher similarity measure to merge. The goal in 
computing similarity measure is to ensure that groups with 
strong similarity in their roles (in terms of connection 
5 patterns) yield a large measure. Guidelines can be used in 
computing the similarity measure between groups including 
favoring groups that form a subset relation and favoring groups 
that have similar average numbers of connections. 

"SIMILARITY" computes the similarity measure "g s " between 

10 the two groups, Gl and G2, on a scale of 0 to 100. CP(7j, G) 

returns the total number of connections between h and hosts in 
G. The V loop computes the sum of the minimum number of weighted 
connections that the two groups have with each of their common 
neighbor. For each neighbor h of G, the connection between h and 

15 G is weighted according to the properties of the group that h 
belongs to (denoted by Gh) . 

The final similarity measure includes two terms. The first 
term is the ratio of the sum computed earlier to the minimum of 
the number of weighted connections that each group has. Thus, if 

20 a group is a proper subset of another group, the first term will 
evaluate to 1. The second term encourages the groups that have 
similar average numbers of connections by penalizing those 
groups with drastically different numbers of connections, (e.g., 
weighting them not similar). The value Rd is set to 0.4. Since 

25 the first term varies from 0 to 1, the combined similarity 

measure g s could be negative. For simplicity, the similarity 
measure is between 0 and 100 inclusively. 

For the purpose of comparing connection sets, some groups 
should be deemed more valuable as a neighbor than some other 

30 groups. For instance, a connection with a server group is 

considered more valuable than a connection with a non-server 
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group. A group is considered to be server-like if it has a high 
k value. A high k value actually implies that the group's 
average number of connections is high. A procedure WEIGHT 
calculates the weight of a group based on its k value. The 
weights are normalized between 1 and 2. Kma X returns the maximum 
k value assigned to any group. Whenever a new group G is formed 
as a result of combining two existing groups, KG is set to be 
the minimum number of connection pairs a host in G has. Other 
ways to calculate the k value of the new group are possible. 

Model 

Let I be the set of hosts in an enterprise network. The 
role grouping process uses "IH" to denote the number of hosts 
in I. Let similarity be a commutative function from pairs of 
hosts in I to an integer greater than or equal to Q. Thus, if 
similarity (hl,h2) is high, then the grouping process should 
place hosts hi and h2 in the same group. Techniques to define 
similarity so that it is both efficient to compute and yields a 
logical grouping are discussed below. 

A partitioning P of I respects similarity if for all distinct 
groups : 

Similarity (hi, hi) < similarity (M,/z3) 
similarity (hi, hi) < similarity (hl,h3) 

Extending this definition of similarity to define the 
average similarity between a host hi and a group G2, avg 
similarity (hi, G2) is the ratio of the sum of the similarity 
between hi and each h2eG to the number of hosts in G2. 

avg similarity (hi , G2) = X h2 Zh2 eG similarit Y (hi, G2)/ 1 G2 1 
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A partitioning P of I respects average similarity if 
V h g G and (71 e P if the average similar of (h,G) is greater 
than or equal to the average similarity of (h, Gl) . Similarity 
5 or average similarity is not sufficient to generate a useful 

partitioning of I, since a partitioning that puts all the nodes 
in one group or one that puts each node in a separate group can 
be based on similarity. The process has a parameter that can be 
used by network administrators to control how aggressive role 

10 grouping process is in partitioning nodes into groups. 

Let Sh, the similarity threshold, be an integer greater Q. 
A partitioning of hosts into groups respects similarity and Sh, 
if the partitioning respects similarity and if, for hi and h2 in 
G, similarity (hl y h2) > Sh . 

15 A partitioning P of I is said to be maximal with respect to 

similarity and S h if the partitioning P of I respects similarity 
and S h and there does not exist another partitioning of I that 
respects similarity and S h and has a larger average group size. 
By increasing Sh, the grouping provides a maximal grouping with 

20 fewer groups in which the members of each group are more similar 
to each other. 

Defining Similarity 

Role grouping of hosts is based on connection habits 
between hosts. Similarity is defined in way that captures the 

25 extent to which pairs of nodes establish connections with each 
other. The role grouping process defines similarity between 
hosts as a function of the number of common hosts with which the 
pair of hosts communicate. A connection is a pair having a 
source host address and a destination host address. The 

30 connection set of a host, [CH) is the set, {a | a 6 I and there 
is a connection between h and a}. If hi 6 C(h2), then h2 6 
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C(hl). A relation neighbor (hl,h2) is defined to be true if and 
only if hi = h2 or hi e C(h2). For later use, a neighbor to 
groups is extended by defining neighbor (G1,G2) to be true if 
and only if there exists a host hi € Gl that is a neighbor of 
5 another host h2 e G2 . 

The notion of a connection set provides a simple definition 
of similarity: 

( 1 ) similarity (hi , h 2) = \C (hi n C (h 2)\ 

10 

That is, similarity hi, h2 is equal to the number of one 
hop neighbors that hosts hi and h2 have in common. The 
requirements of a grouping process can be specified. Given a set 
of hosts, I and a similarity threshold, S h , the grouping process 

15 finds a partitioning, P of I that is maximal with respect to 
average similarity and S h , i.e., that P respects average 
similarity. This constraint guarantees that each host is within 
the group with which it has the strongest average similarity 
(V h g G and Gle P , avg similarity (h,G) > Sh) . This guarantees 

20 that each host in a group is sufficiently closely related to 

every other host in the group, ensuring that groups are not too 
large and that there is no other partitioning P of I that meets 
the first two requirements and has a larger average group size. 
This guarantees that groups are not too small. 

25 FIG. 24 above shows the evolution of the grouping process 

at various k values. Note that this is independent of the 
definition of avg__similarity. For some networks, e.g., the one 
represented in FIG. 19, the above definition of avg_similarity 
may provide good results. 

30 Role Correlation 
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Over time, connection habits may evolve as new servers and 
clients are added to a network while some existing hosts 
(servers and clients) leave the network. Sometimes hosts may 
behave erratically as a result of being victims or villains of 
5 denial of service (DOS) attacks. Due to any of these behaviors 
and others, the grouping process 30 may produce a drastically 
different set of groups than a grouping produced by the process 
a few days previously. As explained, the grouping process 30 
assigns an integer ID to each group of hosts that it identifies. 

10 There is no guarantee that the sets of IDs produced by different 
executions of the grouping process will have any correlation 
between them. This is clearly undesirable to the users who may 
want to associate logical names and configurations to the group 
IDs and preserve these group specific data throughout the 

15 executions of the grouping process. 

Referring to FIG. 26, a group correlation process 270 that 
takes 272 two sets of results produced by the grouping process 
200a and correlates 274 the IDs of one set with those of the 
other set so that the two groups, one in each set of resulting 

20 groups, that have almost identical connection habits will have 
the same ID. 

The process 270 uses a unique host identifier that does not 
change. In some implementations the IP address may be used. In 
others it may not be sufficient when the Dynamic Host Control 

25 Protocol (DHCP) is used since a host's IP address may change 
over time. One solution is to use DNS names as unique 
identifiers and dynamically update the changes in IP addresses. 
Other techniques may be used to deal with hosts that have link 
local IP addresses, which may change periodically. 

30 The connection habits of a host may change as a result of 

arrival of new hosts, removal of existing hosts, and role 
changes by existing hosts. Due to one of these events, some 
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existing hosts may communicate with different sets of hosts and 
thus, the results of the grouping process 30 before and after 
these events may be different. For instance, new groups can be 
formed or existing groups can be deleted. In addition, as the 
set of members belonging to an existing group changes, the 
connection set of an existing group changes. The changes affect 
the hosts directly involved in the aforementioned events and 
other hosts whose connection habits have not changed. This is 
because the changes in connection habits of a host also affect 
the similarity in connection patterns between that host and 
other hosts. 

Given awareness of every single event that happens between 
two executions of the grouping process 30, the results of the 
first execution could be incrementally updated to achieve the 
new results. However, this is not realistic. The whole purpose 
of the grouping process 30 is to use the information available 
in the network and automatically generate grouping results that 
are meaningful to the users. Hypothetically, if the exact 
sequence of every single change event that happened between the 
two executions of the grouping process is known (e.g., by 
logging changes in a change log) , the results of the first 
execution could be incrementally updated to achieve the new 
results. Having such a change log, although not impossible, can 
complicate network data gathering. 

A detailed change log may not lead to correct ID 
correlations. Consider an example in which two nodes, A and B 
that are in different groups switch their roles. Assume that 
node C, which used to communicate with A now communicates with B 
instead. From the change log, it would seem that the connection 
habits of both C and B changed, whereas in reality C's logical 
role never changed. The difficulty here is in distinguishing 
which changes in connection habits are the primary effects that 
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result in different group formations between the two executions 
of the grouping process 32. Furthermore, there may also be 
natural changes in connection habits of many nodes. For 
instance, an existing server machine may be replaced by two new 
5 machines that do load sharing among client machines. The logical 
roles of the client machines have not changed but their 
connection patterns have. 

Described below is a role correlation process that does not 
rely on a change log but rather uses the same set of information 
10 made available to the grouping process 32. 

Role Correlation Process 

Referring to FIG. 27, an implementation of role correlation 
process 270 is shown. The role correlation process 270 compares 

15 282 the results of two executions of the grouping process 30. 
Let G*" 1 and G t be the group sets generated by the grouping 
process at time t-1 and t respectively. The correlation process 
270 updates 284 the ID set of G fc , ID (G t ) so that ID(g t_1 ) = 
ID(g t ) where q t is a member of the set G t and g t_1 is a member of 

20 the set G t if q t and g t_1 are considered to be the same group, 

i.e., if the connection habits of the members of q t and those of 
q^ 1 are very similar. The group correlation process correlates 
286 the ID(g t ) and ID(g t ~ 1 ) in a manner that allows applications 
to preserve data specific to a particular group. The role 

25 correlation process isolates primary events, such as node 

arrivals and removals that directly affect the connection habits 
of groups, identifies nodes that have not changed their 
neighbors and heuristically computes the similarity between the 
connection habits of two groups. The role correlation process 

30 assigns 288 IDCg 1 ") = to ID(g t_1 ) only if g t-1 has the highest 
degree of similarity with g fc . 
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Referring to FIG. 28, the correlation process 270 removes 
290 differences between the two host sets, H fc and H t-1 so that the 
correlation process 270 can compare 292 the connection patterns 
of the hosts. The process computes 294 a set of nodes that 
5 existed at time t-1 but have been removed in time t, and a set 
of nodes that only appear at time t. These two computed sets 
represent the difference sets between H t and H t_1 . All new nodes 
are removed from H* and deleted nodes are removed from H*' 1 . Thus, 
the changes in the connection set of each host are only as a 

10 direct result of changing connection patterns between the host 
and its neighbors (which existed at time t) . 

The process attempts to correlate groups between G t and G t_1 
by determining 296 the similarity between the connection habits 
of hosts in each group. To do so, the process identifies the 

15 set, H same , of nodes that have not changed their neighbors from t- 
1 to t. For the two groups, q t and g t_1 , the similarity is 
computed as follows: 

If both groups have a common host neighbor, nH sa me is a 
member of H same , then the similarity value is simply the minimum 

20 value of the average numbers of connections that q t and g t " 1 , have 
with nH same . For all neighboring nodes nh* nh t_1 that are not in 
nH sam e the relation between Nh fc and g fc are considered similar to 
that between Nh t_1 and g t_1 if the total number of connections 
between Nh 1 and g fc is close to the total number of connections 

25 between between Nh t ' 1 and g*" 1 . The similarity value between a 

similar neighbor pair, nh fc nh t_1 , is again computed as the minimum 
of the average number of connection between Nh t ~ 1 and g*"* 1 and 
that between Nh t and q t . 

The degree of similarity between q t and g*" 1 is the sum of 

30 the similarity values that q t and g t " 1 have with their similar 
neighbors. For all of the groups g* that are a member of G t , 
and groups g t " 1 that are a member of G t_1 that remain uncorrelated, 
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the process determines whether q t and g*' 1 are similar based on 
how similar the connection patterns between q t and its neighbor 
groups are to the connection patterns between g t " 1 and its 
neighbor groups. 

5 To decide whether nh* and nh*"" 1 are similar the process 270 

uses the total number of connections between the neighbor host 
and the group as a factor to decide whether the two groups share 
similar neighbors. All neighbors of g t that are not in Hs am e are 
sorted in descending order using the total number of connection 

10 between the neighbor host and q t as a key. This sorting is 

repeated for g t " 1 and its neighbors. The process 270 examines 
the two-sorted lists. Each list has a pointer, pointing to its 
first element. The two neighbor hosts that the two pointers 
point to are compared to see whether the total number of 

15 connections each node has with the corresponding group is within 
a specified threshold. If so, the total similarity value between 
g fc and g t_1 is incremented as explained earlier. Otherwise, the 
process 270 increments one of the pointers that points to the 
neighbor host with the greater total number connection with the 

20 group. The two groups q t and g*"" 1 are considered to be similar 
only if the degree of similarity between the two groups is 
greater than the predetermined threshold. 

The aforementioned heuristics are applicable for a 
relatively small number of changes in the connection habits of 

25 the groups. In extreme situations, many groups may still remain 
uncorrelated. Another process to correlate the remaining 
uncorrelated groups examines the connection habits between 
groups. The two groups q t and g t_1 are considered similar if C(g t ) 
and C(g t_1 ) are similar. 

30 The similarity between group connection habits, as opposed 

to host connection habits, is used to make the decision 298 on 
whether the two groups, g fc and g t_1 are logically similar. The 
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group connection habits of a group g, C(g) are the set of pairs 
in which each pair (n, ng) is made up of the neighbor group, ng 
and the total number of connections, n, between g and ng. The 
technique for determining whether C{q t ) and Ciq^' 1 ) are similar, 
5 is similar to the technique used for determining whether the 
connection patterns to the neighbor hosts are similar (as 
discussed above) , and thus is omitted for brevity. 

Feedback Mechanism and Graphical User Interfaces 

10 Referring to FIG. 29, an overview graphical user interface 

302 (GUI), provides an operator with an aggregated view of 
network status. The overview graphical user interface 302 
displays a list of events 304 identified by the system 10. 
Within the list of events 304, the overview graphical user 

15 interface 302 shows information such as indicating whether the 
events are new events and includes parametric information 
pertaining to the event such as Severity, Date, Time, Duration, 
Type of event, Source, Destination, and Action Taken. Severity 
is bucketed into various categories such as low, medium, and 

20 high. The severity is determined based on what percentage of an 
established threshold for issuing an event notification is 
reached by the event. The type of event can be any of the types 
of events monitored by the system 10 and can include event types 
such as "worm propagation", "unauthorized access", "DDoS attack" 

25 "historical anomaly" and so forth. 

Destination and source fields are populated with IP 
addresses, as well as, role classification of the host in the 
network. For instance, for the source on the DDOS attack the 
source host is shown by an network address "205.14.12.224" and 

30 the role is displayed as "(Role 3)", which could be an assigned 
role in the system or an alphanumeric or equivalent 
identification. The destination is similarly identified by 
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network address, e.g., 205.13.132.205 and role, (Role 3). 
Actions taken can include any of the actions permissible in the 
system such that the event was "Logged", as shown or other 
actions . 

5 The overview graphical user interface 302 also displays 

network statistics 306 such as the number of bytes per second 
and packets per second of each type of protocol observed in the 
system, e.g., TCP, UDP, ICMP and Other, as noted. The overview 
graphical user interface 302 displays 308 the highest ranked 

10 hosts according to some statistical measure, e.g., by packets 
per second or other statistical measure. 

Referring to FIG. 30, to view the details of an event, a 
user can click on the line-item in the overview graphical user 
interface 302 and launch an event details screen 310. The event 

15 details screen 310 provides further detail about events. In 

particular, the event details screen 310 provides a summary 312 
of the anomalies identified as part of the event. In the 
summary 312 the event severity as well as details such as the 
Date/Time, Source, Destination, and Protocol used are displayed 

20 along with values for these items. Event severity is coded, 

e.g., by a color or other indicia 313 applied to the event or an 
icon to attract the user's attention. 

The event details screen 310 also includes an alert action 
region 314 where a user can "snooze" future alerts related to 

25 this event for a fixed period of time (for example, while the 
event is being addressed) . The "snooze" feature can be for 
selected event types, sourced from "All Roles' 7 for a defined 
period of time. A control "clear this alert from the Overview 
Page" will appear if the alert appears on the overview page. 

30 That is, the "clear this alert from the Overview Page" can be 

launched from the Alert Report page on an event that was cleared 
from the overview page. 
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An event details region 316 of the event details screen 310 
depicts those anomalies that were used to classify the event. 
For instance in FIG XI, the event details screen 310 displays 
what has happened, i.e., current statistics on anomalies 
5 detected and historical values for these anomalies, such as the 
anomalies that a probe is experiencing. 

A significant and rapid increase in Bytes Per Second (based 
on historical values) and can actual identify the probe, e.g., 
"Probe 3: 4308 BPS normal and 200000 BPS current." A similar 

10 measure can be provided for packets per second as shown. 

In addition, in the illustrated example, "252" occurrences 
of the anomaly of the type: "A host attempted to connect with 
multiple other hosts rapidly" occurred. The event details 
region 316 indicates that the hosts, e.g., Host "1.2.3.4" if 

15 operating under a normal connection rate would have historically 
had two (2) connections/minute attempted, the whereas the 
operator can observe the much higher rate of 20 connections/min 
and can take action based on the connection rate. For instance, 
the event details region 316 allows a user to select "details" 

20 that will show details about the selected anomaly. For example, 
if the user clicks on the first "details" link in the list, the 
user is presented with the list of IP addresses to which the 
host attempted to connect. 

Referring to FIG. 31, a process 319 to minimize false 

25 assertions of alert conditions and train algorithms to recognize 
when anomalies should or should not be classified as events is 
shown. The process provides 319 an operator with a list of 
events identified by the intrusion detection system. Within the 
list of events is information that indicates event severity, 

30 with severity determined based on an event having a percentage 
relationship to an established threshold for issuing an event 
notification, as discussed above. The information can be 
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provided by the overview graphical user interface 302, The 
overview graphical user interface 302 displays the list of 
events. Selecting 319b one of the listing of events launches 
the event details screen 310 displaying details of a selected 
5 one of the events to a user. 

The user can "snooze" 319c future alerts related to the 
selected event by selecting the snooze control in the event 
details screen 310. Future alerts related to the selected event 
can be snoozed for a fixed period of time. The snooze control 

10 allows a user to select event types and roles. The event 

details screen 310 allows a user to clear a selected alert from 
the list of events and displays event details including 
anomalies that were used to classify the event. The event 
details screen 310 indicates normal operating conditions of a 

15 host and current operating conditions of a host to allow the 
operator to take action. Examples of the operating conditions 
displayed include normal and current connection rates of the 
host, packets per second (PPS) and bytes per second (BPS) and so 
forth. 

20 The process can display network statistics and display a 

ranking of hosts in the network according to a network 
statistical measure. The network statistical measure can be a 
number of bytes per second and/or packets per second of each 
type of protocol observed in the system. 

25 The event types include worm propagation, unauthorized 

access, denial of service attacks, and historical anomaly 
detections. Other event details that can be displayed include 
destination and source fields populated with IP addresses and 
role classification of the host in the network. 

30 Reports 
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Referring to FIGS. 32-36, the system provides reports 
including the following: "an event history report" 320, "a host 
profile statistics report" 330, "a role profile statistics 
report" 3.40, and "a probe profile statistics report 350." 
5 Referring to FIG. 32, the event history report 320, depicts 

similar information as in the top portion 322 of the overview 
GUI 300 (FIG. 29) . The event history report 320 also includes a 
"time widget tool" 324, which allows a user to select a time 
range over which to base the report. As with the overview 

10 interface 300, clicking on a specific alert will pop up the 

event details screen 310. This report allows the user to search 
all of the events triggered during the specified time period. 

Referring to FIG. 33. a host profile report 330 is shown. 
The host profile report 330 includes a search region 332 that 

15 allows a user to search for a particular host by entering an 

exact IP address (in which case, the profile information appears 
directly or specifying a CIDR block and selecting the host from 
a list of IP addresses matching that CIDR block that have been 
seen on the network. Also the search region 332 of the host 

20 profile report 330 has a field 332b that allows a user to 

specify a role and select the host from a list of IP addresses 
within that role. A user can specify a CIDR block and Role and 
select a host from a list of IP addresses within that role and 
CIDR block. This report shows in a first list 334 traffic 

25 statistics for the selected host and in a second list 336 

traffic statistics for traffic between that host and its peers. 
By clicking on a details link 337, the user will see more 
detailed traffic statistics for the traffic between the host and 
the selected peer. 

30 Thus, a search for the IP address "26.231.0.0/16 yields the 

IP addresses and packet per second rates as in Table 2: 
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Table 2 



IP address 


In 


Out 


26.231.34.1 


0 


0 


26.231.34.2 


lk 


500 


26.231.34.3 


0 


0 


26.231.34.4 


0 


0 


26.231.34.5 


500k 


20k 


26.231.34.6 


36k 


10k 



Clicking on one of the entries depicts the profile for that 
IP address, (e.g., 26.231.34.5) will launch the profile shown in 
5 the FIG. 32 indicating that the profile for "26 . 231 . 34 . 5" 

indicates that the host "26 . 231 . 34 . 5" is a member of "Employee 
Desktops'' role, and will depict totals of traffic into the host 
and out of the host in table 364 and flow statistics in table 
366. Clicking on a peer shows the profile for that peer host. 

10 Clicking on the details link pops up the connection (a->b and b- 
>a) statistics for the peer. 

Referring to FIG. 34 a role profiles alert report 340 is 
shown. The role profiles alert report 340 includes a field 341 
that selects a role to evaluate. The role profiles alert report 

15 340 depicts for a specific role traffic statistics for the role 
in a table 342, traffic statistics for the hosts within the role 
in a table 344, and traffic statistics for traffic between the 
role and its peer roles a table 346. By clicking on a details 
link 345 in table 344 or a details link 347 in table 346, the 

20 user can see more detailed traffic statistics for traffic 
between the role and the selected peer role. 

Referring to FIG. 35, a role profile report for a probe 350 
is depicted. The role profile report for a probe 350 is 
provided by selecting a probe from a dropdown list 352 on the 
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left side of the report 350. The user may view the traffic 
statistic for that probe on a protocol and in/out basis for 
bytes per second (BPS), packets per second (PPS) and connections 
per second (CPS) in table 354. 
5 Referring to FIG. 36, roles are provided by a role grouping 

process as described above. The system 10 includes an interface 
380 for manually defining roles and assigning defined roles to 
sets of hosts. To make the process efficient in large networks, 
the system 10 has an automated role discovery process. The 

10 system collects data from the network, analyzes the behavior of 
different devices and assigns devices with similar behavior, 
e.g., connection behavior to the same role. Once discovered, 
roles can be renamed or otherwise changed by the operator. When 
a new device appears on the network, if it matches some known 

15 role, it can be automatically assigned to that role. 

The interface 380 allows role assignments to be "User 
selected" or "automatic." The interface 380 displays a list 382 
of roles, and by selecting one of the roles, the interface 380 
displays a second list 384 of assigned hosts to the particular 

20 role, along with the host's IP address. The interface 380 

includes controls 385 "Add", "Remove", "Modify", and "New" which 
allows roles to be edited or added to. 

The interface 380 also displays a list 386 of unassigned 
hosts and provides proposed assignments 387 of roles to the 

25 unassigned hosts, indicates that a new role needs to be 

produced, or that a newly discovered host is being evaluated. 
Controls 388 "Add", "Remove" and "Add to proposed role" control 
the addition of hosts in the unassigned list 386 to the roles 
depicted in list 382. Also, the Remove control in control set 

30 388 allows the interface to remove a previously assigned host 

and place that host in the unassigned list 386. Done closes the 
interface 380. 
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Referring to FIGS . 37-40, sensitivity level settings are 
set at different sensitivity levels for different roles per 
event type. 

Referring to FIG. 37, various event types are depicted in 
5 the window that provides a region where event detection settings 
can be set. For instance, for a worm propagation event the 
event status rules for worm propagation can be viewed or edited. 
For instance, detection can be enabled for various heuristic- 
specific settings. The window allows a user to select an event 

10 type, and for that event, set the global, heuristic-specific 
variables. The system can have reasonable defaults for these 
parameters. Also, the window allows the user to set role- 
specific thresholds for low, medium, and high severities. 
Referring to FIG. 38, a setup screen allows general 

15 settings such as specifying where to send SNMP traps to, details 
of the overview screen and frequency of profile periods over 
which to collect a new profile. 

Referring to FIG. 39, a screen 420 provides automation 
options that allows for role management or role assignment. The 

20 user can have the system recommend an assignment but disable 
auto-assign, or can have the system use auto-assign to assign 
new hosts to the role that best matches the host's behavior. 
The interface can select the amount of time over which to 
monitor a host's connection behavior in order to determine role 

25 match. These settings allow the user to adjust the automation 
rules for assigning roles to groups. 

Referring to FIG. 40, a user management screen 430 allows 
the user to add, modify, and remove users. Users can be granted 
various permissions including User Level Permissions, monitor 

30 and operator. The administrator can change any setting. The 
operator level allows the user to snooze alerts. 
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A number of embodiments of the invention have been 
described. Nevertheless, it will be understood that various 
modifications may be made without departing from the spirit and 
scope of the invention. 
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